The following is a partial list of Tools Plus features. Nearly all of them need only one line of code calling a Tools Plus routine. Although some of these features may appear to be simple, their functional equivalent, when programmed in ordinary C or Pascal, often requires considerable programming effort and dozens (often hundreds) of lines of code. Unlike object oriented class libraries that add thousands of lines of code to your application, Tools Plus reduces the need for most of your user interface and event management code.
The key advantages to every Tools Plus routine is:
• virtually all features can be implemented with a single line
of code
• they are consistent across all Systems and Macintosh models
• they are fully integrated with each other
• they adopt the “set and forget” principle of self-maintenance
allowing you to easily create a user interface, then forget about
it. Your application responds to very specific events, such as:
Pop-up menu was selected in Window 5, Pop-Up Menu 3, Item 6.
W i n d o w s
~~~~~~~~~~
All 6 standard window types are supported and are referenced by a window number instead of a pointer. Pointers can be used, if required. Additionally, Tools Plus provides your application with full tool bar and floating palette services.
Any window can be “modal” to prevent the use of menus or clicking outside the active window.
All Tools Plus user interface elements (such as buttons, editing fields, etc.) created in a window are automatically maintained. Just create them and forget them. Tools Plus takes care of drawing them and making them work.
Windows can be optionally centered on the main monitor, or tiled.
When a window is deactivated, Tools Plus automatically deactivates of all the user interface elements by disabling buttons, deselecting and disabling editing fields, disabling button and picture buttons, disabling pop-up menus, etc. When the window is activated, Tools Plus restores the objects to their original state.
Windows with title bars are moved automatically when they are dragged by the user. Tools Plus ensures that windows are not dragged completely off the screen or underneath the tool bar.
Windows with a “size box” are automatically sized when the user drags the “size box.” Minimum and maximum limits can be specified for horizontal and vertical size. You can also limit the window to horizontal and/or vertical sizing only.
Windows with an optional “zoom box” in their title bar automatically zoom between a standard size/position, and a user-controlled size/position.
All Tools Plus user interface elements (such as buttons, editing fields, etc.) created by your application are automatically refreshed when needed.
Each window’s update region is “protected” to exclude Tools Plus’s user interface elements, so your application can refresh a window’s contents without concern about overwriting buttons, scroll bars, editing fields, etc.
When a window needs to be refreshed, your application can redraw custom objects (such as a picture background) before and/or after Tools Plus redraws its objects.
Your application can reposition, resize, or hide/show windows and still have Tools Plus maintain the user interface correctly. No code is required to compensate for these actions.
Various routines are provided to help your application keep track of windows: front most, current, active, front most floating palette, front most standard window, most recently used, containing active editing field, and more
Closing a window automatically releases the memory occupied by Tools Plus user interface elements such as its buttons, scroll bars, editing fields, list boxes, etc.
T o o l B a r
~~~~~~~~~~
Your application can optionally have a tool bar which is created below the menu bar on your main monitor. Your application treats the tool bar just like any other window, and can open and close the tool bar as required.
A tool bar’s width is automatically set to the main monitor’s width. Your application just has to specify the tool bar’s height.
The tool bar always remains the front window and is always active. It can contain any Tools Plus user interface element, including pop-up menus, editing fields and picture buttons.
The tool bar is automatically hidden when your application is suspended under MultiFinder (System 5 and 6), or System 7. When your application is activated, the tool bar is displayed again.
The tool bar can optionally shift all your application’s windows downward as it opens. This prevents windows from being partially obscured by the tool bar. If this option is used, windows are shifted back up when the tool bar is closed.
If the tool bar’s size is changed by your application (to add or remove a data entry area, for example), all open windows can optionally be shifted to accommodate the difference in tool bar size.
Windows cannot be dragged beneath the tool bar.
F l o a t i n g P a l e t t e s
~~~~~~~~~~~~~~~~~~~~~~
Floating palettes (often called “palettes” or “windoids”) are supported. They are as easy to use as any other window in Tools Plus.
You can use third-party window definitions (WDEFs) or write your own to get a specific look. Tools Plus takes care of making the window behave like a floating palette
Palettes always remain in front of standard windows (if any are open) and behind the tool bar (if there is one). They can contain any Tools Plus user interface element, including pop-up menus, editing fields and picture buttons.
Floating palettes are moved automatically when they are dragged by the user. Tools Plus ensures that floating palettes are not dragged completely off the screen or underneath the tool bar.
When the user clicks on an object (such as a picture button) in floating palette, that palette is quickly brought to the front and refreshed before the click is processed. This results in very responsive palettes.
Palettes are automatically hidden when your application is suspended under MultiFinder (System 5 and 6), or System 7. When your application is activated, the palettes are displayed again.
Two styles of palettes are included with Tools Plus: one with a title bar along the top of the palette (with optional title), and a second style that has a drag bar along the left side of the palette. The second style is well suited for horizontally oriented palettes that need to be as small as possible (the drag bar takes little space).
B u t t o n s
~~~~~~~~~
All 3 types of Macintosh buttons (push button, radio button and check box) are supported, and are referenced by a button number instead of a handle.
Buttons can be enabled or disabled with a simple command.
Check boxes and radio buttons can be checked or unchecked with a simple command.
A push button can be designated to be the default button for a window. As per Macintosh standards, a black outline is drawn around the button, and it is automatically selected whenever the user types Return or Enter.
Buttons are automatically disabled when their parent window is inactive. When the window is reactivated, the buttons assume their normal state.
Each button’s text can be displayed using a different font, sizes, and style. These variations work independently of their parent window’s font settings (unlike ordinary Macintosh buttons).
Your application is informed when a radio button is double-clicked. It can optionally interpret this to mean “select this button and click the default push-button.”
Any push button can be “flashed” to appear as though it was clicked.
P i c t u r e B u t t o n s
~~~~~~~~~~~~~~~~~~~
Any icon or PICT can be transformed into a button. Like regular Tools Plus buttons, picture buttons are referenced by a button number instead of a handle.
Each picture button’s appearance and behavior is defined by selecting from a number of alternate choices. You simply define how the button works.
Picture buttons can be simple, like click-sensitive icons, or they can be complex and provide the appearance of animation.
Color 3D buttons can be produced from a simple black and white icon. Tools Plus calculates the shading and highlighting to make the button appear to stand out from the window, and to be pushed in when selected by the user.
Picture buttons have an optional “value” with a definable value range (similarly to a scroll bar).
Multiple stage picture buttons have a different appearance for each value in the button’s range (such as an “on/off” button that has a value range of 0 and 1, and has the word “on” or “off” displayed).
Buttons can lock into the “selected” position (to behave like radio buttons)
A picture button can be scaled to have its value change at a constant speed, or to accelerate at a slow, moderate, or rapid rate. You can also define a precise rate of change, such as 90° per second.
Picture buttons can optionally produce repeating events as long as the mouse button is held down.
Buttons can be polarized to increase their value when clicked on one side, and decrease when clicked on the other.
Picture buttons can be enabled or disabled with a simple command. You can apply one of several disabling effects to each button, or you can design your own image for a disabled button.
Picture buttons can be selected or deselected with a simple command. You can apply one of several selecting effects to each button, or you can design your own image for a selected button.
Picture buttons are automatically disabled when their parent window is inactive. When the window is reactivated, the buttons assume their normal state.
Any picture button can be “flashed” to appear as though it was clicked.
S c r o l l B a r s
~~~~~~~~~~~~~~
Scroll bars are created with a single command and are referenced by a scroll bar number instead of a handle.
Scroll bars are automatically disabled when their window is inactive. When the window is reactivated, the scroll bars assume their normal state.
If a window has a right and/or bottom scroll bar, such as the kind seen on the edges of word processing documents and spreadsheets, these scroll bars are automatically resized and repositioned when a window’s size is changed. Constants are provided to let you place these scroll bars without having to calculate their exact position.
E d i t i n g F i e l d s
~~~~~~~~~~~~~~~~~
Editing fields are created with a single command and are referenced by a field number instead of a handle. They are also memory efficient to allow for numerous fields in low memory situations.
Tools Plus manages the multiple intricacies that arise when editing fields are included on standard windows, floating palettes, and the tool bar.
The Edit menu automatically interacts with the active editing field. The Undo, Cut, Copy, Paste, and Clear items are automatically enabled/disabled appropriately (see Menus). Selected text is automatically copied to and from the clipboard by using the Edit Menu.
Selected characters in a field automatically become deselected when the field’s window is inactive. When the window is reactivated, selection is restored to its normal state.
Sophisticated text editing allows a selected range of characters to be extended by a single character, or a word at a time. With Tools Plus, editing fields behave like miniature word processors.
Fields can be length-limited to prevent their text from exceeding a specified number of characters. Tools Plus maintains the length limit even when text is pasted into the field.
Tab, Return, Enter, Clicking, and Double-Clicking in a field are all fully supported.
Editing fields can contain single or multiple lines (as decided upon by your application).
Automatic scrolling ensures that selected characters are always in view. In single-line fields, words will not disappear when they exceed the right side of the field -- they are automatically scrolled into view.
Enhanced drag-selection works in conjunction with automatic scrolling making it easy to select additional characters that are out of view. The further you move the cursor out of the field, the quicker it scrolls
Editing fields can be repositioned on a window to facilitate scrolling tables.
Your application can paste text directly into a field under the application’s control.
Each editing field can have its own unique font, size, and style. These variations work independently of the parent window’s font settings (unlike regular Macintosh fields).
L i s t B o x e s
~~~~~~~~~~~~~
Macintosh “list boxes” are supported simply and effectively.
List boxes are created with a single command and are referenced by a list number instead of a handle.
Lines in a list box can be added or deleted as required, and are referenced by line number.
List boxes are automatically disabled (the lines are deselected and the scroll bar is disabled) when their window is inactive, and are enabled when the window is activated.
Various methods are available for selecting lines in a list box, such as: one line only, multiple lines, select as you drag the mouse, and many more.
Your application can determine if a specific line, or any lines are selected in a list box.
When you first create a list box, the first selected line will always be in view (i.e. not scrolled out of view).
Each list box can have its own unique font, size, and style. These variations work independently of the parent window’s font settings (unlike regular Macintosh list boxes).
M e n u s
~~~~~~~
Menus are created by a single command (one for each item) and are referenced by a menu and item number instead of a handle. Hierarchical menus are created the same way.
Menu hierarchies are easily created by simply attaching a submenu to a menu item.
Tools Plus prevents hierarchy errors such as: cyclical hierarchies, submenus attached to multiple parents, Command keys invoking an item in an orphan submenu (i.e., submenu with no parent), etc.
Tools Plus prevents logical menu errors, such as overwriting a submenu link with a command key.
Menus can be added, changed, deleted, renamed, appended, enabled/disabled, restyled, prefaced with a symbol or icon, etc.
Command key equivalents, icons, check marks, other special marks, and font styling are all supported.
The “Apple” menu is created with a single command that automatically gives your application access to desk accessories. This also includes the apple menu’s “About…” item that names your application.
When using the Finder in System 5 or System 6, menus are automatically enabled/disabled appropriately when a desk accessory is active. Under MultiFinder and System 7, the menu bar is automatically replaced with the desk accessory’s menu bar when the DA is active.
The Edit menu’s Undo, Cut, Copy, Paste, and Clear items automatically perform editing functions on the active field and in desk accessories. These menu items are automatically enabled/disabled appropriately.
The Edit menu’s Undo item performs Undo/Redo operations on the active editing field. It automatically changes to “Undo Cut”, “Undo Copy”, “Undo Paste”, and “Undo Typing” as required. Selecting “Undo…” changes the item to “Redo…” and automatically performs the correct action.
P o p - U p M e n u s
~~~~~~~~~~~~~~~~
Pop-up menus are created by a single command (one for each item) and are referenced by a menu and item number instead of a handle.
Also included are “pop-down menus.” They have a fixed (unchanging) title inside the pop-up box, and the available items appear beneath the control’s box.
Tools Plus’s pop-up menus support: “down arrow” suppression, multiple fonts, single item selection, and more.
When displaying a pop-up menu using a font other than the System Font (such as Geneva 9pt), Tools Plus’s pop-up menus are unaffected by other applications which may use non-standard Menu Manager methods (such as a rather famous word processor that resets other application’s pop-up menu fonts).
You can optionally display the selected item’s icon in the pop-up menu’s box.
Pop-up menus can be added, changed, deleted, renamed, appended, enabled/disabled, restyled, prefaced with a symbol or icon, etc.
Icons, check marks, other special marks, and font styling are all supported.
Pop-up menus are automatically disabled when their parent window is inactive. When the window is reactivated, the pop-up menus assume their normal state.
Tools Plus’s pop-up menus look and work the same across all system versions, thereby providing System 7 features to prior systems.
M o u s e
~~~~~~~
Single, double, and triple clicks, as well as dragging is automatically detected and reported.
A cursor table can be used to detect if the mouse was clicked in specific areas (such as a picture or icon). This feature effectively makes any object “click sensitive.”
Event Handling (Polling)
~~~~~~~~~~~~~~~~~~~
A single routine keeps all automatic Tools Plus processes running smoothly, and tells your application if something has occurred, such as the user selecting a menu or clicking a button.
The revolutionary Event Translator reports events in a highly informative, simple, concise, and ready-to-use format instead of being cryptic and requiring message decoding. Example: the “Save” button was selected in the “Add Customer” window (button 4 was selected in window 15), or “Menu Item 16 was selected in Menu 4.” This is much simpler than decoding event messages, tracking controls, and using handles and pointers.
Some events are processed entirely by Tools Plus, such as typing in an active editing field or selecting its text, or using the Edit menu on a field, or running desk accessories. It’s completely automatic.
Tools Plus takes care of maintaining the user interface before it reports an event to your application. For example, in a doRefresh event (refresh a window), all Tools Plus user interface elements (buttons, scroll bars, editing fields, etc.) are redrawn automatically.
Many events can be ignored if your application doesn’t care about them, such as when the user drags or re-sizes a window.
Events that are not processed by Tools Plus are handed to your application, which can either ignore them or process them as required. This allows advanced programmers to implement their own special features.
C l i p b o a r d
~~~~~~~~~~~
The clipboard is automatically maintained when using the Edit menu on an editing field (i.e., the clipboard contains copied text).
Your application can access text that was placed on the clipboard by other applications or desk accessories, so you can paste it into fields by using the Edit menu. No programming is required.
The Edit menu’s “Undo” operation restores the clipboard to its original state, so if you accidentally copy something to the clipboard and undo the copying, the clipboard’s original contents are automatically restored.
C u r s o r s
~~~~~~~~~
The shape of the cursor can be changed with a single command.
The cursor changes shape automatically depending on where it is on the screen. For example, the cursor becomes an I-Beam when it enters an editing field, and an arrow when it is outside the active window.
A cursor table can be set up to automatically change the cursor’s shape depending on its position in a window, so it could become a “plus” cursor when located over a grid of cells (like in a spreadsheet application).
When the wrist watch cursor is displayed, Tools Plus filters out all mouse clicks and typing except Command-. (operator halting a lengthy process.)
Optionally, your application can permit the clicking of a push button when the wrist watch cursor is displayed. This is useful if you have a Cancel button displayed on a window during a lengthy process.
An animated cursor, like the Finder’s spinning wrist watch, is supported. You define the images used to animate the cursor, and the speed at which the animation occurs.
D e s k A c c e s s o r i e s
~~~~~~~~~~~~~~~~~~~~~
Access to desk accessories is made possible by creating the Apple menu with a single command.
The Edit menu’s Undo, Cut, Copy, Paste, and Clear items interact automatically with desk accessories.
Text that is cut, copied and pasted between desk accessories and editing fields in your application is completely automatic.
Desk accessories are handled automatically by Tools Plus (you don’t have to program anything to use them).
D i a l o g s / A l e r t s
~~~~~~~~~~~~~~~~~~
Alerts and modal dialog boxes are supported by standard C or Pascal statements, however, they can be easily simulated by using Tools Plus windows or Tools Plus’s Dynamic Alerts.
D y n a m i c A l e r t s
~~~~~~~~~~~~~~~~~~~
Dynamic Alerts are alerts (or simple dialogs) that are automatically sized in relation to the alert’s contents -- they grow as big as needed to always appear aesthetically pleasing. It’s like having hundreds of customized alert boxes available at your disposal.
Dynamic Alerts are created with a single command, and do not require the use of resources.
You can use various combinations of Yes, No, OK, and Cancel buttons, or define your own combinations. A default button can be optionally specified.
An icon can be optionally displayed, and the alert can optionally beep when displayed.
Dynamic Alerts, unlike Macintosh alerts, are unaffected by screen savers.
Dynamic Alerts are always centered perfectly on the main monitor, regardless of the monitor’s size or the number of monitors used.
C u s t o m C o n t r o l s
~~~~~~~~~~~~~~~~~~~~
Advanced programmers can develop their own custom controls and still be informed of events pertaining to those controls.
E x t r a s
~~~~~~~~
Zoom lines, such as those displayed by the Finder when a document is opened, are available to make objects appear to zoom out from the screen or zoom back down again.
All icon types (cicn, icl8, icl4, ics8, ics4, ics#, SICN, ICON, and ICN#) can be drawn with a single command. Icons can be displayed as selected/unselected and enabled/disabled. Tools Plus is sensitive to monitor settings (number of colors) and displays the best available icon. Icons are displayed correctly even if they straddle two monitors with dissimilar settings.
The standard Macintosh thermometer can be drawn with a single command. Tools Plus is sensitive to monitor settings (number of colors), as well as whether you are using System 7 or not, and draws a thermometer that is identical to the Finder’s.
M o n i t o r s
~~~~~~~~~~~
Color, gray-scale and monochrome (black and white) monitors are supported, as are multiple-monitor setups. Specialized routines are included to facilitate color-dependent drawing, and to inform your application of its environment.
M e m o r y
~~~~~~~~
Memory fragmentation due to opening and closing windows is eliminated, regardless of the number of windows your application uses or has open at the same time.
Tools Plus is memory efficient, requiring little of your application’s memory for its own overhead.
S y s t e m s
~~~~~~~~~~
Tools Plus can be compiled into applications intended for System 5 and System 6 (Finder and MultiFinder), System 7, and Power Macintosh (in emulation or native mode).